

WHAT IS CLAIMED IS:

1. A method for modeling a circuit design comprising:
  - synthesizing a circuit design to create a first gate-level representation of the circuit design;
  - analyzing a second gate-level representation of the circuit design to learn architecture information; and
  - resynthesizing the first gate-level representation of the circuit design to incorporate the learned architecture information from the second gate-level representation of the circuit design.
- 10 2. The method of Claim 1, wherein the second gate-level representation being created during a synthesis process.
3. The method of Claim 1, wherein the learned architecture information comprises logic network architecture in the second gate-level representation of the circuit design.
- 15 4. The method of Claim 1, wherein the analyzing comprises a resource sharing learning.

*sub A1* >
- 20 5. The method of Claim 4, wherein the resource sharing learning comprising:
  - creating one or more resource pairs from sharable resources in the first gate-level representation of the circuit design;
  - for each of the one or more resource pairs, synthesizing a subcircuit that shares the resource pair;
  - for each of the synthesized subcircuits, calculating a similarity with a corresponding subcircuit in the second gate-level representation of the circuit design;
  - identifying the synthesized subcircuits having a high similarity with the corresponding subcircuit in the second gate-level representation of the circuit design; and
  - resynthesizing the first gate-level representation of the circuit design to include the subcircuits identified as having high similarity.
- 25 6. The method of Claim 1, wherein the analyzing comprises an operator order learning.

- 5-5 A2 7. The method of Claim 6, wherein the operator order learning comprising:  
creating one or more operand pairs from operations in the first gate-level representation of the circuit design;  
for each of the one or more operand pairs, synthesizing a subcircuit for the operand pair;  
for each of the synthesized subcircuits, calculating a similarity with a corresponding subcircuit in the second gate-level representation of the circuit design;  
identifying the synthesized subcircuits having a high similarity with the corresponding subcircuit in the second gate-level representation of the circuit design; and  
resynthesizing the first gate-level representation of the circuit design to include the subcircuits identified as having high similarity.
- 10 8. The method of Claim 7 further comprising, for each of the synthesized subcircuits having high similarity, creating a new operand that signifies the output of the operand pair associated with the synthesized subcircuit.
- 15 9. The method of Claim 1, wherein the analyzing comprises a multiplier learning.
- 20 10. The method of Claim 9, wherein the multiplier learning comprising:  
identifying a multiplier in the first gate-level representation of the circuit design;  
identifying a corresponding multiplier subcircuit in the second gate-level representation of the circuit design;  
synthesizing the multiplier in the first gate-level representation with a partial product generation implementation;  
calculating a similarity for the synthesized partial product generation subcircuit with the partial product generation subcircuit in the corresponding multiplier in the second gate-level representation; and  
resynthesizing the multiplier in the first gate-level representation to have the partial product generation most similar to the partial product generation in the second gate-level representation.
- 25 30

- sub A3 >* 11. The method of Claim 9, wherein the multiplier learning comprising:  
analyzing a reduction tree structure in the second gate-level representation  
of the circuit design; and  
resynthesizing a reduction tree in the first gate-level representation from  
the reduction tree structure learned from the second gate-level representation.  
5
12. The method of Claim 1, wherein the analyzing comprises an operator  
merging learning.
- sub A4 >* 13. The method of Claim 12, wherein the operator merging  
learning comprising:  
10 expressing a complex operation in the first gate-level representation as  
a summation;  
analyzing a reduction tree structure in the second gate-level representation  
of the circuit design, the reduction tree corresponds to the complex operation; and  
resynthesizing a reduction tree in the first gate-level representation from  
the reduction tree structure learned from the second gate-level representation.  
15
14. The method of Claim 1, wherein the analyzing comprising:  
identifying a first subcircuit in the first gate-level representation of the  
circuit design;  
20 identifying a second subcircuit in the second gate-level representation of  
the circuit design, the second subcircuit corresponding to the first subcircuit; and  
calculating a similarity between the first subcircuit and the  
second subcircuit.
15. The method of Claim 14, wherein calculating the similarity comprises  
checking one or more circuit structures.
- 25 16. The method of Claim 14, wherein calculating the similarity comprises  
checking one or more boolean functions.
17. The method of Claim 14, wherein calculating the similarity comprises  
performing one or more simulations.
- 30 18. A computer-readable storage medium having stored thereon computer  
instructions that, when executed by a computer, cause the computer to:  
synthesize a circuit design to create a first gate-level representation of the  
circuit design;

analyze a second gate-level representation of the circuit design to learn architecture information; and

resynthesize the first gate-level representation of the circuit design to incorporate the learned architecture information from the second gate-level representation of the circuit design.

5 19. The computer-readable storage medium of Claim 18, wherein the second gate-level representation being created during a synthesis process.

10 20. The computer-readable storage medium of Claim 18, wherein the learned architecture information comprises logic network architecture in the second gate-level representation of the circuit design.

21. The computer-readable storage medium of Claim 18, wherein the analyzing comprises a resource sharing learning.

15 22. The computer-readable storage medium of Claim 21, wherein the computer instructions that perform resource sharing learning further comprise computer instructions that, when executed by a computer, cause the computer to:

create one or more resource pairs from sharable resources in the first gate-level representation of the circuit design;

for each of the one or more resource pairs, synthesize a subcircuit that shares the resource pair;

20 for each of the synthesized subcircuits, calculate a similarity with a corresponding subcircuit in the second gate-level representation of the circuit design;

25 identify the synthesized subcircuits having a high similarity with the corresponding subcircuit in the second gate-level representation of the circuit design; and

resynthesize the first gate-level representation of the circuit design to include the subcircuits identified as having high similarity.

23. The computer-readable storage medium of Claim 18, wherein the analyzing comprises an operator order learning.

30 24. The computer-readable storage medium of Claim 23, wherein the computer instructions that perform operator order learning further comprise computer instructions that, when executed by a computer, cause the computer to:

*sub AP* create one or more operand pairs from operations in the first gate-level representation of the circuit design;

*cont'd* for each of the one or more operand pairs, synthesize a subcircuit for the operand pair;

5 for each of the synthesized subcircuits, calculate a similarity with a corresponding subcircuit in the second gate-level representation of the circuit design;

10 identify the synthesized subcircuits having a high similarity with the corresponding subcircuit in the second gate-level representation of the circuit design; and

resynthesize the first gate-level representation of the circuit design to include the subcircuits identified as having high similarity.

25. The computer-readable storage medium of Claim 24, wherein the computer instructions that perform operator order learning further comprise computer instructions that, when executed by a computer, cause the computer to, for each of the synthesized subcircuits having high similarity, create a new operand that signifies the output of the operand pair associated with the synthesized subcircuit.

26. The computer-readable storage medium of Claim 18, wherein the analyzing comprises a multiplier learning.

20 *sub AP* 27. The computer-readable storage medium of Claim 26, wherein the computer instructions that perform multiplier learning further comprise computer instructions that, when executed by a computer, cause the computer to:

identify a multiplier in the first gate-level representation of the circuit design;

25 identify a corresponding multiplier subcircuit in the second gate-level representation of the circuit design;

synthesize the multiplier in the first gate-level representation with a partial product generation implementation;

30 calculate a similarity for the synthesized partial product generation subcircuit with the partial product generation subcircuit in the corresponding multiplier in the second gate-level representation; and

*svs A2* resynthesizes the multiplier in the first gate-level representation to have the partial product generation most similar to the partial product generation in the second gate-level representation.

5 28. The computer-readable storage medium of Claim 26, wherein the computer instructions that perform multiplier learning further comprise computer instructions that, when executed by a computer, cause the computer to:

analyze a reduction tree structure in the second gate-level representation of the circuit design; and

10 29. The computer-readable storage medium of Claim 18, wherein the analyzing comprises an operator merging learning.

*svs A3* 30. The computer-readable storage medium of Claim 29, wherein the computer instructions that perform operator merging learning further comprise computer instructions that, when executed by a computer, cause the computer to:

express a complex operation in the first gate-level representation as a summation;

analyze a reduction tree structure in the second gate-level representation of the circuit design, the reduction tree corresponds to the complex operation; and

20 31. The computer-readable storage medium of Claim 26, wherein the computer instructions that perform analyzing further comprise computer instructions that, when executed by a computer, cause the computer to:

25 identify a first subcircuit in the first gate-level representation of the circuit design;  
identify a second subcircuit in the second gate-level representation of the circuit design, the second subcircuit corresponding to the first subcircuit; and  
calculate a similarity between the first subcircuit and the second subcircuit.

30 32. The computer-readable storage medium of Claim 31, wherein calculating the similarity comprises checking one or more circuit structures.

33. The computer-readable storage medium of Claim 31, wherein calculating the similarity comprises checking one or more boolean functions.

34. The computer-readable storage medium of Claim 31, wherein calculating the similarity comprises performing one or more simulations.

Add